

#### 香港中文大學

The Chinese University of Hong Kong

CENG3430 Rapid Prototyping of Digital Systems

# Lecture 02: Introduction to ZedBoard





#### **Outline**



- Digital System Design Basics
  - Integrated Circuit Technology
  - Design Flow of Digital Systems
  - Spectrum of Design Technologies
- Zynq: All-Programmable SoC (APSoC)
  - Our Board: ZedBoard
    - ZedBoard Layout and Interfaces
    - Specifying ZedBoard in Vivado
    - Hardware Setup for ZedBoard
    - Programming the ZedBoard
    - Xilinx Design Constraints (XDC) File



# Integrated Circuit Technology



- Integrated circuit (IC) technology has improved to allow more and more components on a chip.
  - Small Scale Integration (SSI): 1 to 20 gates
  - Medium Scale Integration (MSI): 20 to 200 gates
  - Large Scale Integration (LSI): 200 to few thousands gates
  - Very Large Scale Integration (VLSI): More than 10,000 gates
  - Ultra Large Scale Integration (ULSI): 100 million transistors
- Digital system design have become more complex.









# Design Flow of Digital Systems (1/6)



- All the designs start with design requirements and design specifications.
- The next step is to formulate the design conceptually.
  - Either at a block diagram level or at an algorithmic level.





# Design Flow of Digital Systems (2/6)



- Design Entry:
  - Olden days: Hand-drawn schematic or blueprint
  - Now: Computer-aided design (CAD) tools
    - Schematic Capture: Design with gates, flip-flops, and standard building blocks.
      - E.g., ORCAD
    - Hardware Descriptions
       Languages (HDLs): Design and debug at higher level
      - E.g., VHDL and Verilog



# Design Flow of Digital Systems (3/6)



- The entered design then should be simulated.
  - To ensure it function correctly at high-level behavioral model
  - To unveil problems in the design
- Recall: In Lab01, we run
  - Click "Flow" → "Run Simulation" → "Run Behavioral Simulation"





# Design Flow of Digital Systems (4/6)



- Logic Synthesis
  - Convert the high-level abstract descriptions to components at the gate and flip-flop levels
    - Netlist: Outputs of synthesis tool
      - Specify internal connections
- Post-Synthesis Simulation
  - Test specific implementations of the hardware components
- Mapping, Placement, Routing
  - Mapped into the specific target
  - Placed into specific parts
  - Route the paths of connections



### Design Flow of Digital Systems (5/6)



- Two most common targets:
  - Field Programmable Gate Array (FPGA)
    - Programming simply involves writing a sequence of 0's and 1's into the programmable cells of FPGA.
  - AISC or SoC

 The routed design is used to generate a <u>photomask</u> for producing integrated circuits (ICs).





#### Design Flow of Digital Systems (6/6)





#### **Spectrum of Design Technologies**





Density and Degree of Customization

#### **Outline**



- Digital System Design Basics
  - Integrated Circuit Technology
  - Design Flow of Digital Systems
  - Spectrum of Design Technologies
- Zynq: All-Programmable SoC (APSoC)
  - Our Board: ZedBoard
    - ZedBoard Layout and Interfaces
    - Specifying ZedBoard in Vivado
    - Hardware Setup for ZedBoard
    - Programming the ZedBoard
    - Xilinx Design Constraints (XDC) File



# Zynq: All-Programmable SoC (1/2)



- All-Programmable SoC (APSoC): Zynq provides an more ideal platform for implementing flexible SoCs.
- Zynq comprises two main parts:
  - Programmable Logic (PL): equivalent to that of an FPGA
  - Processing System (PS): formed around a dual-core ARM Cortex-A9 processor



# Zynq: All-Programmable SoC (2/2)



- Programmable Logic (PL): Implements high-speed logic, arithmetic and data flow subsystems.
- Processing System (PS): Supports software routines and/or operating systems.
  - The overall functionality of any designed system can be appropriately partitioned between hardware and software.
- Advanced eXtensible Interface (AXI):
  - Links between the PL and PS are made using industry standard Advanced eXtensible Interface (AXI) connections.



### **Processing System (PS)**



- PS supports software routines and operating systems.
  - The overall functionality of any system can be partitioned.
- PS has a "hard" dual-core ARM Cortex-A9 processor.
  - Hard processors can achieve higher performance.
- By contrast, "soft" processor (e.g., Xilinx MicroBlaze) can be made by the programmable logic elements.
  - The number and precise implementation of soft processor



#### Programmable Logic (PL)



- PL section is ideal for implementing high-speed logic, arithmetic and data flow subsystems.
- PL is composed of general purpose FPGA logic fabric.



#### **Zynq Development Setup**



- Joint Test Action Group (JTAG): Downloading designs onto the development board over JTAG
- Universal Asynchronous Receiver/Transmitter (UART) and Terminal Applications: Interfacing and debugging



#### Our Board: Zynq ZedBoard



ZedBoard: Zynq Evaluation and Development Board



#### **ZedBoard Layout and Interfaces**



- ZedBoard features a ZC7Z020 Zynq device.
  - Artix-7 logic fabric, with a capacity of 13,300 logic slices, 220
     DSP48E1s, and 140 BlockRAMs
  - DDR3 Memory, and Flash
  - Several peripheral interfaces
  - A Xilinx JTAG connector

h XADC header port

- b Power input and switch
- Configuration jumpers
- C USB-JTAG (programming)
- FMC connector

d Audio ports

k SD card (underside)

e Ethernet port

User push buttons

f HDMI port (output)

m LEDs

9 VGA port

n Switches



- OLED display
- Prog & reset push buttons
- 9 5 x Pmod connector ports
- r USB-OTG peripheral port
- S USB-UART port
- DDR3 memory
- U Zynq device (+ heatsink)

#### Specifying ZedBoard in Vivado



- ZedBoard Zynq Evaluation and Development Kit:
  - The design tools have knowledge of the specific facilities and peripheral connections of ZedBoard.
- Target part: xc7z020clg484-1, Rev: d



#### Hardware Setup for ZedBoard



- The ZedBoard must be connected to a power supply.
- By default, ZedBoard connects to the host PC for programming over USB-JTAG.
- An additional connection can USB-UART be made over USB-UART.
  - If intending to facilitate simple board-PC communication using the Terminal application.
- Note that there is also a third micro-USB port for connecting USB peripherals (USB-OTG)



**USB-OTG** 

# Programming the ZedBoard (1/2)



- ZedBoard can be programmed in four different ways:
  - USB-JTAG: This is the default and most straightforward method of programming the ZedBoard, given that it can be done directly over the USB-micro-USB cable supplied in the ZedBoard kit.
  - Traditional JTAG: A Xilinx JTAG connector is available on the board and may be used in place of the USB-JTAG connection, if desired. This will require a different type of cable or a *Digilent USB-JTAG programming cable*.
  - Quad-SPI flash memory: The non-volatile flash memory on the board can be used to store configuration data which persists when the board is powered off. Using this method removes the requirement for a wired connection to program the Zynq device.
  - SD card: There is an SD slot on the underside of the ZedBoard.
     This facility can be used to program the Zynq with files stored on the SD card, thus requiring no wired connections.

# Programming the ZedBoard (2/2)



- The ZedBoard user specifies the method of booting / programming via a set of jumper pins.
  - The middle three are for specifying programming source.

|                                         | MIO[6]           | MIO[5]           | MIO[4]           | MIO[3]           | MIO[2]           |
|-----------------------------------------|------------------|------------------|------------------|------------------|------------------|
| In Xilinx Technical<br>Reference Manual | Boot_<br>Mode[4] | Boot_<br>Mode[0] | Boot_<br>Mode[2] | Boot_<br>Mode[1] | Boot_<br>Mode[3] |
| JTAG Mode                               |                  |                  |                  |                  |                  |
| Cascaded JTAG <sup>a</sup>              | -                | -                | -                | -                | 0                |
| Independent JTAG                        | -                | -                | -                | -                | 1                |
| Boot Device                             |                  |                  |                  |                  |                  |
| JTAG                                    | -                | 0                | 0                | 0                | -                |
| Quad-SPI (flash)                        | -                | 1                | 0                | 0                | -                |
| SD Card <sup>a</sup>                    | -                | 1                | 1                | 0                | -                |
| PLL Mode                                |                  |                  |                  |                  |                  |
| PLL Used <sup>a</sup>                   | 0                | -                | -                | -                | -                |
| PLL Bypassed                            | 1                | -                | -                | -                | -                |

Cascaded: A single JTAG connection is used to interface to the debug access ports in both the PS and PL.



The *PLL* mode determines whether the process of configuring the device includes a phase of waiting for the PLL to lock.

# Xilinx Design Constraints (XDC)



- XDC: A file that maps <u>external I/Os of the design</u> to physical pins on the ZedBoard.
  - External interfaces examples: switches, LEDs
  - For example: C <= A and B;</pre>
    - set property PACKAGE PIN T22 [get ports {C}]; # "LDO"
    - set\_property PACKAGE\_PIN F22 [get\_ports {A}]; # "SWO"
    - set property PACKAGE PIN G22 [get ports {B}]; # "SW1"
    - Note: Voltage levels also need to be specified (see Lab02).



#### Class Exercise 2.1



- Complete the XDC file for the design C <= A and B
  with the following pin assignments on ZedBoard:</li>
  - A: Switch #6 (SW6)
  - **B**: Switch #7 (SW7)
  - C: LED #7 (LD7)



#### **Summary**



- Digital System Design Basics
  - Integrated Circuit Technology
  - Design Flow of Digital Systems
  - Spectrum of Design Technologies
- Zynq: All-Programmable SoC (APSoC)
  - Our Board: ZedBoard
    - ZedBoard Layout and Interfaces
    - Specifying ZedBoard in Vivado
    - Hardware Setup for ZedBoard
    - Programming the ZedBoard
    - Xilinx Design Constraints (XDC) File

